# Calcolatori Elettronici II

## Esempio di IO mediante interruzioni LA PIA

Materiale didattico a cura di:

Prof. A. Mazzeo Ing. L. Romano Ing. L. Coppolino Ing. A. Cilardo

Dipartimento di Informatica e Sistemistica Università Degli Studi di Napoli Federico II

DIS - Dipartimento di Informatica e Sistemistica



# Il dispositivo PIA di ASIM - 1/2

- > Name
  - » M6821PIA
- ➤ Type
  - » Identificativo assoluto nella configurazione
- ➤ Address1
  - » Indirizzo base
- ➤ Address2
  - » Indirizzo base + 3
- > BUS
  - » Identificatore del bus esterno a cui il dispositivo è connesso



## Il dispositivo PIA di ASIM - 2/2

### ➤ COM1

» Identificatore del dispositivo di gestione delle interruzioni generate dall'oggetto

### ➤ COM2

» Controllo linea interruzione IRQA: XXYZ (XX=#vettore, Y=livello priorità, Z=linea di interruzione)

#### ➤ COM3

» Controllo linea interruzione IRQB: XXYZ (XX=#vettore, Y=livello priorità , Z=linea di interruzione)

### ➤ COM4

» Identificatore assoluto dell'oggetto a cui il porto parallelo è connesso





## PIA (Periferal Interface Adapter)

- Dispositivo parallelo a parallelismo 8 bit
- due sezioni quasi identiche di 8 bit dati configurabili, anche singolarmente, come linee di ingresso o di uscita
- due coppie di linee di controllo per la sincronizzazione
  - » CA1 e CB1 sono sempre di ingresso al dispositivo
  - » CA2 e CB2, possono essere programmate per operare sia in ingresso sia in uscita per implementare forme di handshaking



# Programmazione PIA

- Dispositivo PIA simulato in ASIM è derivato da quello commerciale MC6821
- Sei registri a 8 bit:
  - » due registri per il trasferimento dei dati da e verso la periferica (PRA e PRB)
  - » due registri di controllo/stato (CRA e CRB)
  - » due registri, DRA e DRB, per il controllo della direzione dei dati (in input o in output)





# Indirizzamento dei registri

6 registri e 4 indirizzi → indirizzamento interno

| AD1 | AD0 | CRA2 | CRB2 | Registro Selezionato |
|-----|-----|------|------|----------------------|
| 0   | 0   | 1    | X    | PRA                  |
| 0   | 0   | 0    | X    | DRA                  |
| 0   | 1   | X    | X    | CRA                  |
| 1   | 0   | X    | 1    | PRB                  |
| 1   | 0   | X    | 0    | DRB                  |
| 1   | 1   | X    | X    | CRB                  |

X : indifferente.



## I registri di controllo

|     | 7     | 6     | 5             | 4 | 3   | 3           | 1             | 0       |
|-----|-------|-------|---------------|---|-----|-------------|---------------|---------|
| CRA | IRQA1 | IRQA2 | Controllo CA2 |   | CA2 | Accesso DRA | Controllo CA1 |         |
| CRB | 7     | 6     | 5             | 4 | m   | 2           | 1             | 0       |
|     | IRQB1 | IRQB2 | Controllo CB2 |   | :B2 | Accesso DRB | Contro        | 110 CB1 |

- Controllo di CA1 (o CB1): consente di controllare il flag di interruzione IRQA1 (IRQB1) presente nella parola di stato-controllo di 8 bit posto in posizione b7
  - » Lo stato del flag IRQA1 si ripercuote sulla linea di interruzione IRQA verso il processore generando una interruzione





## I registri di controllo

- Controllo di CA2 (o CB2): è differente a seconda che tale linea sia stata programmata per operare come linea di ingresso o di uscita.
  - » <u>CA2 (o CB2) come linea di ingresso (b5=0):</u> si comporta come CA1 (CB1) con
    - ☞b3 nella funzione di b0
    - ☞b4 nella funzione di b1
    - FIRQA2 (IRQB2) nella funzione di IRQA1 (IRQB2)
  - » <u>CA2 o (CB2) come linea di uscita (b5=1): i</u>n tal caso CA2 consente di controllare la periferica. Sono previsti 3 possibili modi di sincronizzazione codificati con i bit b4 e b3



# Controllo delle linee di ingresso

| CRA1<br>(CRB1) | CRA0<br>(CRB0) | Flag Interruzione<br>CRA7 (CRB7) | Richiesta Interr<br>IRQA (IRQB)               |
|----------------|----------------|----------------------------------|-----------------------------------------------|
| 0              | 0              | Alto su high/low<br>di CA1 (CB1) | Disabilitata                                  |
| 0              | 1              | Alto su high/low<br>di CA1 (CB1) | Inviata quando<br>CRA7 (CRB7)<br>diventa alto |
| 1              | 0              | Alto su low/high<br>di CA1 (CB1) | Disabilitata                                  |
| 1              | 1              | Alto su low/high<br>di CA1 (CB1) | Inviata quando<br>CRA7 (CRB7)<br>diventa alto |

| Il flag di interruzione CRA7 (CRB7) torna al valore bass |
|----------------------------------------------------------|
| in seguito ad un' operazione di lettura su PRA (PRB).    |

| CRAS   |        | CRA3   | Flag Interruzione | Richiesta Interr |
|--------|--------|--------|-------------------|------------------|
| (CRB5) | (CRB4) | (CRB3) | CRA6 (CRB6)       | IRQA (IRQB)      |
| 0      | n      | О      | Alto su high/low  | Disabilitata     |
| , u    | 0      | U      | di CA2 (CB2)      |                  |
| n      | 0      | 1      | Alto su high/low  | Inviata quando   |
|        | U      | 1      | dá CA2 (CB2)      | CRA6 (CRB6)      |
|        |        |        |                   | diventa alto     |
|        | -      | _      | Alto su low/high  | Disabilitata     |
| "      | 1      | 0      | di CA2 (CB2)      |                  |
| n      |        | 1      | Alto su low/high  | Inviata quando   |
| "      | , I    | 1      | di CA2 (CB2)      | CRA6 (CRB6)      |
|        |        |        |                   | diventa alto     |
|        |        |        |                   |                  |

Il flag di interruzione CRA6 (CRB6) torna al valore basso in seguito ad un' operazione di lettura su PRA (PRB).

DIS - Dipartimento di Informatica e Sistemistica



# Controllo delle linee di uscita: CA2

Tabella 6 : Controllo della linea di uscita CA2

| Tabella 0 . Conta ono della inica di distita CA2 |   |      |                                                                                          |                                                                                                  |  |  |
|--------------------------------------------------|---|------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--|--|
|                                                  |   |      | C A2                                                                                     |                                                                                                  |  |  |
| CRA5 CRA4 CRA3                                   |   | CRA3 | BASSO                                                                                    | ALTO                                                                                             |  |  |
| 1                                                | 0 | 0    | Basso in seguito ad un' opera-<br>zione di lettura su PRA                                | Alto quando CRA7 va ad 1 per<br>una variazione h/l o l/h di CA1                                  |  |  |
| 1                                                | 0 | 1    | Basso in seguito ad un' opera-<br>zione di lettura su PRA                                | Alto al primo colpo di clock<br>successivo alla lettura su PRA                                   |  |  |
| 1                                                | 1 | 0    | Basso quando CRA3 diviene<br>basso in seguito ad un' opera-<br>zione di scrittura su CRA | Sempre basso finche CRA3 è<br>basso. Diviene alto seCRA3 va<br>ad 1 per un' op. di scritt. suCRA |  |  |
| 1                                                | 1 | 1    | -                                                                                        | Alto quando CRA3 diviene alto<br>in seguito ad un' operazione di<br>scrittura su CRA             |  |  |



### Controllo delle linee di uscita: CB2

Tabella 5 : Controllo della linea di uscita CB2

|                |   |      | CB2                                                                                      |                                                                                                    |  |
|----------------|---|------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--|
| CRB5 CRB4 CRB3 |   | CRB3 | BASSO                                                                                    | ALTO                                                                                               |  |
| 1              | 0 | 0    | Basso in seguito ad un' opera-<br>zione di scrittura su PRB                              | Alto quando CRB7 va ad 1 per<br>una variazione h/1 o l/h di CB1                                    |  |
| 1              | 0 | 1    | Basso in seguito ad un' opera-<br>zione di scrittura su PRB                              | Alto al primo colpo di clock<br>successivo la scrittura su PRB                                     |  |
| 1              | 1 | 0    | Basso quando CRB3 diviene<br>basso in seguito ad un' opera-<br>zione di scrittura su CRB | Sempre basso finche CRB3 è<br>basso. Diviene alto se CRB3 va<br>ad 1 per un' op. di scritt. su CRB |  |
| 1              | 1 | 1    |                                                                                          | Alto quando CRB3 diviene alto<br>in seguito ad un' operazione di<br>scrittura su CRB               |  |

DIS - Dipartimento di Informatica e Sistemistica



## Connessione 1/2

- "Com4" viene utilizzato per specificare l'eventuale dispositivo periferico cui M6821PIA è connesso
  - » nell'attuale versione di ASIM, l'unico dispositivo cui un M6821PIA può essere connesso è un altro M6821PIA
- Com4 = XYZZ
  - » ZZ = Id del dispositivo connesso
  - » XY definiscono la modalità di connessione dei dispositivi

## Connessione 2/2

- Com4 = XYZZ
  - » Y
    - 0 linea CA2 connessa alla linea CA1 del dispositivo periferico;
    - 1 linea CA2 connessa alla linea CA2 del dispositivo periferico;
    - 2 linea CA2 connessa alla linea CB1 del dispositivo periferico;
    - 3 linea CA2 connessa alla linea CB2 del dispositivo periferico;
  - **»** X
    - 0 linea CB2 connessa alla linea CA1 del dispositivo periferico;
    - 1 linea CB2 connessa alla linea CA2 del dispositivo periferico;
    - 2 linea CB2 connessa alla linea CB1 del dispositivo periferico;
    - 3 linea CB2 connessa alla linea CB2 del dispositivo periferico;







# Configurazione Sistema 1

### SISTEMA 1

CHIP Name: MEMORY

Type: MMU/BUS.Identif: 01. BUS: 0000. Addres 1: 00008000. Address 2: 00000000.

Com1: 0000. Com2: 0010. Com3: 0008. Com4: 0000

CHIP Name: M68000

Type: CPU. Identif: 02. BUS: 0001. Addres 1: 00009000. Address 2: 00009200.

Com1: 0000. Com2: 0000. Com3: 0000. Com4: 0000.

CHIP Name: TERMINAL

Type: Device. Identif: 03. BUS: 0001. Addres 1: 00002000. Address 2: 00002001.

Com1: 0002. Com2: 0001. Com3: 0002. Com4: 0000.

CHIP Name: M6821PIA
Type: Device. Identif: 04. BUS: 0001.
Addres 1: 00002004. Address 2: 00002007.

Com1: 0002. Com2: 0003. Com3: 0004. Com4: 0208...



## Configurazione Sistema 2

#### SISTEMA 2

CHIP Name: MEMORY

Type: MMU/BUS.Identif: 05. BUS: 0000. Addres 1: 00008000. Address 2: 00000000.

Com1: 0000. Com2: 0010. Com3: 0008. Com4: 0000.

CHIP Name: M68000

Type: CPU. Identif: 06. BUS: 0005. Addres 1: 00009000. Address 2: 00009200.

Com1: 0000. Com2: 0000. Com3: 0000. Com4: 0000.

CHIP Name: TERMINAL

Type: Device. Identif: 07. BUS: 0005. Address 1: 00002000. Address 2: 00002001.

Com1: 0006. Com2: 0001. Com3: 0002. Com4: 0000.

CHIP Name: M6821PIA

Type: Device. Identif: 08. BUS: 0005. Addres 1: 00002004. Address 2: 00002007.

Com1: 0006. Com2: 0003. Com3: 0004. Com4: 0204.









## Configurazione Memoria

- Livelli d'interruzione associati al terminale:
  - » Interruzione per Enter
    - » livello 1, autovettore 25, mappata a \$64, ISR a \$8500
  - » Interruzione per Buffer Full
    - » livello 2, autovettore 26, mappata a \$68, ISR a \$8600
- ➤ Livelli d'interruzione associati alla PIA:
  - » Interruzione su linea IRQA abilitata
    - » livello 3, autovettore 27, mappata a \$6C, ISR \$8700
  - » Interruzione su linea IRQB DISABILITATA
    - » livello 4, autoverrore 28, mappata a \$70, ISR \$8700



DIS - Dipartimento di Informatica e Sistemistica

## Esecuzione 1/2







